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fsj (57) Abstract: The invention relates to a data processing unit (VPU) comprising logic cells (PAEs) clocked in operational fields 
in different configuration states and a clocking input means for setting the clocking of the logic cell. According to the invention, 

Othe clocking input means is configured in such a way that it can provide one type of clocking to at least one first cell (PAE) in a 
K slate-dependent manner, and provide another type of clocking to at least one other cell. 
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(57) Zusammenfassung: Die Erfindung betriflt eine Daienverarbeitungseinheit (VPU) mil einem in unterschiedlichen Konfigurau- 
onszustanden betreibbaren Feld getakteter Logikzellen (PAEs) und einem Taktvorgabemittel zur Vorgabe einerLogikzellentaktung. 
Hierbei ist vorgesehen, dass das Taktvorgabemittel dazu ausgebildet ist, zustandsabhangig an zumindest einer ersten Zelle (PAE) 
einen ersten und an zumindest einer weiteren Zelle einen weiteren Takt vorzugeben. 
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Titel: Verfahren und Vorrichtungen zur Datenbe- und/oder 

Verarbeitung 

Beschreibung 

Die vorliegende Erfindung betrifft das oberbegrif f lich Bean- 
spruchte und befasst sich somit mit der Frage, wie bei der 
Datenverarbeitung eine Optimierung der verwendeten Hardware 
erreicht werden kann. 

Bei der Datenverarbeitung ist es erf orderlich, sowohl die 
verfugbaren Ressourcen zu optimieren, als auch den Energie- 
verbrauch der mit der Datenverarbeitung befassten Schaltun- 
gen. Dies gilt insbesondere' bei rekonf igurierbaren Prozesso- 
ren, 

Unter einer rekonfigurierbaren Architektur werden vorliegend 
Bausteine (VPU) mit konf igurierbarer Funktion und/oder Ver- 
netzung verstanden, insbesondere integrierte Bausteine mit 
einer Mehrzahl von- ein- oder mehrdimensional angeordneten 
arithmetischen und/oder logischen und/oder analogen und/oder 
speichernden und/oder intern/extern vernetzenden Baugruppen, 
die direkt oder durch ein Bussystem miteinander verbunden 
sind. 

Zur Gattung dieser Bausteine zahlen insbesondere systolische 
Arrays, neuronale Netze, Mehrprozessor Systeme, Prozessoren 
mit mehreren Rechenwerken und/oder logischen Zellen und/oder 
kommunikativen/peripheren Zellen (-10), Vernetzungs- und Netz- 
werkbausteine wie z.B. Crossbar-Schalter, ebenso wie bekannte 
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Bausteine der Gattung FPGA, DPGA, Chameleon, XPUTER, etc.. 
Hingewiesen wird insbesondere in diesem Zusammenhang auf die 
folgenden Schutzrechte und Anmeldungen desselben Anmelders: P 
44 16 881.0-53, DE 197 81 412.3, DE 197 81 483.2, 
5 DE 196 54 846.2-53, DE 196 54 593.5-53, DE 197 04 044.6-53, 
DE 198 80 129.7, DE 198 61 088.2-53, DE 199 80 312.9, 
PCT/DE 00/01869, DE 100 36 627.9-33, DE 100 28 397.7, 
DE 101 10 530.4, DE 101 11 014.6, PCT/EP 00/10516, 
EP 01 102 674.7, PCT/DE 97/02949 (PACT02/PCT) , PCT/DE 
10 97/02998 (PACT04/PCT) , PCT/DE 97/02999 (PACT05/PCT) , PCT/DE 
98/00334 (PACT08/PCT) , PCT/DE 99/00504. (PACTlOb/PCT) , PCT/DE 
99/00505 (PACT10c/PCT)., DE 101 39 170.6 (PACT11), DE 101 42 
'903.7 (PACTlla), DE 101 44 732.9 (PACTllb) , DE 101 45 792.8 . 
(PACTllc), DE 101 54 260.7 (PACTlld) , DE 102 07 225.6 
15 (PACTlle), PCT/DE 00/01869 (PACT13/PCT) , DE 101 42 904.5 
(PACT21), DE 101 44 733.7 (PACT21a) , DE 101 54 259.3 
(PACT21b), DE 102 07 226.4 (PACT21c) , PCT/DE 00/01869 
(PACT13/PCT) , DE 101 10 530.4 (PACT18),DE 101 11 014.6 
(PACT18a), DE 101 46 132.1 (PACT18II), DE 102 02 044.2 
20 (PACT19), DE 102 02 175.9 (PACT19a), DE 101 35 210.7 
(PACT25), DE 101 35 211.5 (PACT25a) , DE 101 42 231.8 
(PACT25aII), (PACT25b.) . Diese sind hiermit zu. Of fenbarungs- 
zwecken vollumf anglich eingegliedert . 

25 Die o.g. Architektur wird beispielhaft zur Verdeutlichung 
herangezogen und im folgenden VPU genannt. Die Architektur 
besteht aus beliebigen arithmetischen, logischen (auch Spei- 
cher) und/oder Speicherzellen und/oder Vernetzungszellen 
und/oder koitimunikativen/peripheren (IO) Zellen (PAEs) , die zu 

30 . einer ein- oder mehrdimensionalen Matrix (PA) angeordnet sein 
konrien, wobei die. Matrix unterschiedliche beliebig ausgestal- 
tete Zellen aufweisen kann, auch die Bussysteme werden dabei 
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als Zellen verstanden. Der Matrix als ganzes oder Teilen da- 
von zugeordnet ist eine Konf igurationseinheit (CT), die die 
Vernetzung und Funktion des PA durch Konf igurations bestimmt. 
Die Konf iguration einer VPU wird durch das Schreiben von Kon- 

5 f igurationsworten in Konf igurationsregister bestimmt. Jedes 
Konf igurationswort bestimmt eine Teilfunktion. PAEs konnen 
mehrere Konf igurationsworte fur ihre Konf iguration benotigen, 
beispielsweise eines/oder mehrere fur die Vernetzung der PAE, 
eines/oder mehrere fur die Taktbestimmung und eines/oder meh- 

10 rere zur Auswahl einer ALU- Funktion, etc. 

Es ist bekannt, dass ein Prozessor, der mit hoherer Taktfre- 
quenz betrieben wird, mehr Leistung erfordert. Bei modernen 
Prozessoren steigen daher die Anforderungen an die Kuhlung 
15 mit zunehmender Taktfrequenz stark an. Oberdies muss ein Mehr 
an Leistungsversorgung bereit gestellt werden, was insbeson- 
dere bei mobilen Anwendungen kritisch ist. 

Es ist bereits bekahnt, zustandsabhangig die Taktfrequenz fur 
20 einen Microprozessor zu bestimmen. Derartige Techniken sind 
aus dem Bereich mobiler Computer bekannt. Dabei ergeben sich 
jedoch Probleme in der Gesamtgeschwindigkeit, mit der be- 
st immte Anwendungen ausgefuhrt werden. 

25 Aufgabe der Erfindung ist es Neues fur die gewerbliche Anwen- 
dung bereitzustellen. 

Die Losung dieser Aufgabe wird unabhangig beansprucht. 

30 Die vorliegehde Erfindung gibt somit an, wie der Stromver- 
brauch bei einer VPU-Technqlogie verringert und/oder opti- 
miert werden kann. Es. sei darauf hingewiesen, dass, soweit im 

- 3 - 
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Nachfolgenden unterschiedliche Verfahren hierzu angesprochen 
werden, diese einzeln oder in Kombination Vorteile bringen. 

Gemafl einem ersten wesentlichen Aspekt der Erfindung wird al- 
5 so bei einer Datenverarbeitungseinheit (VPU) mit einem in un- 
terschiedlichen Konf igurationszustanden betreibbaren Feld ge- 
takteter Logikzellen (PAEs) und einem Taktvorgabemittel zur 
Vorgabe einer Logikzellentaktung das Taktvorgabemittel dazu 
ausgebildet, zustandsabhangig an zumindest einer ersten Zelle 
10 (PAE) einen ersten und an zumindest einer weiteren Zelle 
(PAE) einen weiteren Takt vorzugeben. 

Es wird also vorgeschlagen, unterschiedliche Zellen mit un- 
terschiedlicher Taktung zu betreiben. Der weitere Takt wird 

15 in der Regel auf den ersten bezogen sein, also in definierter 
Phasenlage zu diesem stehen. Dazu wird, urn optimale Datenver- 
arbeitungsergebnisse, insbesondere sowohl im Hinblick auf die 
benotigte Datenverarbeitungszeit als auch den Energiever- 
brauch der gesamten Datenverarbeitungseinheit zu erzielen, 

20 vorgeschlagen, dass die Taktung zustandsabhangig erfolgt, 
dass also nicht etwa abhangig von einem jeweiligen Zustand 
alien Zellen gemeinsam ein Takt vorgegeben wird, sondern je- 
der Zelle abhangig vom Zustand ein geeigneter Takt zugeordnet 
wird. 

25 

Weiterhin wird vorgeschlagen die Taktung global konfigurier- 
bar zu gestalten, derart dass. eine Einstellung (Konf igurati- 
on) die Taktung der Gesamtzahl von Zellen gemeinsam bee in-- 
f luBt . 

30 

Es ist moglich und gewunscht, wenn das Taktvorgabemittel dazu 
ausgebildet ist, den Solltakt fur wenigstens eine erste Zelle 

4 - 
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von einer Konf igurationszustande vorgebenden Einheit zu emp- 
fangen. Dies ermoglicht es, die Taktung der Zelle abhangig 
von ihrer Konf igurierung bereits dann zu wahlen, wenn diese 
Konf igurierung festgelegt wird. Dies hat den Vorteil, dass 
5 problemfrei eine Konf igurierung erfolgen kann. 

Bei der Konf igurationszustande vorgebenden Einheit kann es 
sich einerseits urn eine Compilereinheit handeln, das heifit, 
es wird bereits beim Compilieren des Programmes die erforder- 

10 liche Oder gewunschte Taktung der Zelle festgelegt. Wenn die 
Compilereinheit die Konf igurationszustande vorgibt, kann die 
Zellkonfigurationsvorgabeeinheit die Taktung zur Zellkonfigu- 
ration an eine zu konf igurierende Zelle ubermitteln . Dies ist 
vorteilhaft, weil es moglich ist, dann lediglich das Konfigu- 

15 rationswort beziehungsweise den Konf igurationsbef ehl, mit dem 
die Konfiguration einer Zelle festgelegt wird, urn eine takt- 
bestimmende Angabe zu erweitern, ohne dass weitere Mafinahmen 
erforderlich sind, wie beispielsweise die Implement ie rung von 
taktvergebenden Bussen, auf denen die taktfestlegenden Signa- 

20 le separat ubermittelt werden oder dergleichen; .dass dies 
aber prinzipiell moglich ist, sei erwahnt. 

Es kann auch vorgesehen werden, dass das Taktvorgabemittel 
dazu ausgebildet ist, den Solltakt beziehungsweise ein takt- 

25 beeinf lussendes Signal von einer der weiteren Logikzellen, 
insbesondere einer konf igurierbaren Logikzelle zu empfangen. 
Dies ist insbesondere dann vorteilhaft, wenn in einer ersten 
Logikzelle auf ein Eingangssignal einer externen Einheit ge- 
wartet wird und erst bei Eintreffen derartiger Signale die 

30 nachfolgend eintref f enden Signale verarbeitenden Zellen akti- 
viert werden sollen. Eskann so ein Logikfeldschlafmodus im- 
plementiert werden, bei dem nur eine oder eine Vielzahl von 

- 5 — ' 
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Zellen auf einem - gegebenenf alls sehr geringen Niveau, d.h. 
bereits sehr langsamer Taktung - aktiviert sind und das ver- 
. bleibende Feld extrem langsam getaktet wird. Die dann erfor- 
derlichen Taktf requenzen im Restfeld sind abhangig von den 
5 physikalisch notigen Taktungen, die zum Erhalt von Speiche- 
rinhalten oder dergleichen erforderlich sind. 

Es ist auch dann vorteilhaft, ein taktbeeinf luftendes Signal 
von einer anderen Logikzelle zu empfangen, wenn mit einer Lo- 

10 gikzelle eine oder eine Reihe einer Vielzahl unterschiedli- 
cher arithmetischer und/oder logischer Operationen ausgeftthrt 
werden kann, die zumindest zum Teil eine unterschiedliche An- 
zahl von Taktzyklen erfordern, ohne dass dies vorher von der 
Compilereinheit vollstandig festgelegt werden kann. Auch in 

15 einem solchen Fall brauchen die nachfolgenden Zellen nicht 
zwingend mit hoher Taktfrequenz betrieben werden, wenn sie 
durch entsprechende, den Zustand der in einer Verarbeitungs- 
sequenz mitwirkenden Zelle anzeigenden Signale entsprechend 
herunter getaktet werden. 

20 

In einer bevorzugten Variante umfasst das Taktvorgabemittel 
eine Zentraltaktvorgabeeinheit, beispielsweise einen zentra- 
len Taktgenerator, dessen Takt tiber eine Taktleitung an die 
einzelnen Zellen iibertragen wird, sowie eine Lokaltaktgene- 

25 riereinheit zur Generierung eines Lokaltaktes aus und/oder im 
Ansprechen auf den uber die Taktleitung ubertragenen zentra- 
len Takt. In einer moglichen Ausgestaltung kann die Taktung 
der Zentraltaktvorgabeeinheit durch eine Konf iguration beein- 
flufit bzw. eingestellt werden. Es ist bevorzugt, wenn die Lo- 

30 kaltaktgeneriereinheit durch einen Frequenzteiler und/oder 
Frequenzvervielfacher realisiert, ist und das Frequenzteiler- 
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verhaltnis bestimmt wird durch die Vorgaben des Taktvorgabe- 
mittels gemali der zustandsabhangigen Taktf estlegung . 

In einer bevorzugten Variante umfassen die Logikzellen oder 
5 zumindest einige der Logikzellen wenigstens eine ALU und/oder 
sind durch eine solche gebildet. Es ist moglich und bevor- 
zugt, wenn einige der Logikzellen wenigstens eine Speicher- 
und/oder Registereinheit enthalten, die den restlichen Lo- 
gikzellen zugeordnet werden kann. Insbesondere kann diese fur 
10 zu verarbeitende. Daten und/oder Konf igurationen der Zelle 
vorgesehen sein. 

Es ist moglich, dass eine Vielzahl von Logikzellen identisch 
sind und diese mit unterschiedlicher Taktung entsprechend ih- 
15 rer jeweiligen Konf iguration betrieben werden. Insbesondere 
ist es moglich, dass alle Logikzellen identisch sind. . 

Schutz wird auch beansprucht fur ein Verfahren zum Betreiben 
eines in unterschiedliche Konf igurationszustande bringbaren 

20 Feldes getakteter Logikzellen, wobei zumindest zeitweilig fur 
wenigstens eine erste Zelle ein erster Zustand bestimmt wird, 
abhangig vom ersten Zustand ein der ersten Zelle zuzuordnen- 
der Takt ermittelt und die Zelle mit diesem Takt betrieben 
wird, fur wenigstens eine weitere Zelle ein zweiter Zustand 

25 bestimmt wird, abhangig vom zweiten Zustand ein der zweiten 
Zelle zuzuordnender zweiter Takt ermittelt und die zweite 
Zelle mit diesem vom ersten Takt verschiedenen zweiten Takt 
betrieben wird. 

30 Wie vorerwahnt, kann die Taktung mit der Konf iguration zusam- 
men vorgegeben werden. Der Zustand ist dann der Konf igurati- 
onszustand und/oder durch diesen wenigstens mitbestimmt... 

- 7 - 
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Typisch werden bei bekannten und konf igurierbaren Logikzellen 
Zellen gruppenweise zur Ausfuhrung komplexer Operationen zu- 
sammen gefasst. Wenn dabei einzelne der Zellen Teiloperatio- 

5 nen ausfiihren, die in weniger Taktzyklen ablaufen, als dies 
bei jenen Zellen der Fall ist, die mit besonders langwierigen 
Teiloperationen der komplexen Gesamtoperationen, welche die 
Gruppe ausfuhrt, ist es bevorzugt, wenn diese Zellen mit un- 
terschiedlichen Taktraten betrieben werden, und zwar so, dass 

10 die Zellen fur weniger komplexe Operationen, also fur Opera- 
tionen, die in weniger Taktzyklen ablaufen, langsamer getak- 
tet werden als die anderen Zellen; insbesondere ist es bevor- 
zugt, wenn die Zellen einer Gruppe insgesamt so getaktet 
sind, dass die Anzahl von Leer zyklen innerhalb der Gruppe mi- 

15 nimiert ist. Eine Alternative und/oder Erganzung hierzu be- 
steht darin, mit weniger komplexen Aufgaben belastete Zellen 
temporar fur bestimmte Taktzykluszahlen umzunutzen, also wah- 
rend einer festen Anzahl von Taktzyklen anders zu nutzen, 

20 Insbesondere kann der Fall eintreten, dass die maximale Tak- 
trate von PAEs und/oder PAE-Gruppen durch deren Funktion und 
insbesondere Vernetzung begrenzt wird. Besonders mit fort- 
schreitender Halbleitertechnologie spielt die Laufzeit von 
Signalen iiber Bussysteme eine verstarkt f requenzlimitierende 

25 Rolle. Das Verfahren erlaubt nunmehr die langsamere Taktung 
solcher PAEs und/oder PAE-Gruppen, wahrend andere PAEs 
und/oder PAE-Gruppen mit einer anderen, gegebenenfalls hohe- 
ren, Frequenz arbeiten. In einer vereinf achten Ausfuhrung 
wird vorgeschlagen, die Taktrate des gesamten rekonf igurier- 

30 baren Bausteines (VPU) von der maximalen Taktrate der lang- 
samsten PAE und/oder PAE-Gruppe abhangig zu machen. Mit ande- 
ren Worten kann die Zentraltaktvorgabeeinheit derart konfigu- 
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riert werden, dass der hochste gemeinsame Betriebstakt aller 
PAEs und/oder PAE-Gruppen (quasi der kleinste gemeinsame Nen- 
ner aller Maximaltaktraten) global fur alle PAEs generiert 
wird. 

5 

Das Verfahren wie vorstehend beschrieben ist besonders dann 
vorteilhaft, wenn die Zellen der Gruppe Daten sequentiell 
verarbeiten, das heifit, das Ergebnis, welches eine Zelle be- 
stimmt hat, an eine oder mehrere nachfolgend Daten verarbei- 
10 tende Zellen weitergereicht wird. 

Es sei erwahnt, dass neben der Priorisierung von Aufgaben in- 
' nerhalb des Zellfeldes zur Taktvorgabe auch der Zustand einer 
Leistungsquelle zur Zelltaktungsbestimmung herangezogen wer- 

15 den kann. Insbesondere kann fur mobile Anwendungen bei Abf al- 
ien einer Versorgungsspannung die Taktung insgesamt herunter 
gesetzt* werden. Gleichfalls ist ein Heruntertakten zur Ober- 
temperaturverhinderung im Ansprechen auf ein Temperatursen- 
sorsignal oder dergleichen moglich. Die benutzervorgegebene 

20 Taktungsvorgabe ist ebenfalls moglich. Verschiedene Parameter 
konnen gemeinsam den taktungsbestimmenden Zustand festlegen. 

Vorstehend wurde bereits erwahnt, dass es moglich ist, ein 
Zeitmultiplexing zum Ausfuhren mehrerer Konf igurationen auf 

25 derselben PAE vorzunehmen. Ein besonders ressourcensparendes 
Zeitmultiplexing zum Ausfuhren mehrerer Konf igurationen auf 
derselben PAE wird dabei durch eine bevorzugte. und erweiterte 
Ausgestaltung moglich, die auch unabhangig von der unter- 
schiedlichen Taktung einzelner Zellen Vorteile aufweisen 

30 kann, etwa dann, wenn Latenzzeiten zu beachten sind, wie sie 
sich bei der Signalubertragung digitaler Daten, seien es Kon- 
f igurationsdaten, zu bearbeitende Daten oder dergleichen iiber 
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einen Bus ergeben. Diese Probleme werden besonders gravie- 
rend, wenn rekonf gurierbare Bausteine mit zum Teil ver- 
gleichsweise weit voneinander entfernten rekonf igurierbaren 
Einheiten mit hohen Taktf requenzen betrieben werden sollen. 

5 Dabei entsteht namlich das Problem, dass durch den besonderen 
Aufbau von VPUs eine Vielzahl von beliebigen PAEs iiber Busse 
verbunden sind und ein nicht unwesentlicher Dateniibertra- 
gungsaufwand liber die Busse besteht. In modernen und v. a. zu- 
kunftigen Siliziumtechnologien wird die Schaltfrequenz von 

10 Transistoren weiter ansteigen, wahrend die Signaliibertragung 
iiber Busse verst&rkt zu einem perf ormanceeinschrarikenden Fak- 
tor wird. Vorgeschlagen wird daher, die Datenrate bzw. Fre- 
quenz auf den Bussen gegeniiber der Arbeitsf requenz der daten- 
verarbeitenden PAEs zu entkoppeln. 

15 

Eine besonders einfache und fur einfache Implementierungen 
bevorzugte Ausgestaltung arbeitet dann derart, dass die Tak- 
trate einer VPU nur global einstellbar ist. Mit anderen Wor- 
ten kann ein einstellbarer Takt fur samtliche PAEs vorgegeben 

20 werden bzw. von einer ubergeordneten Konf igurationseinheit 

(CT) konfiguriert werden.. Samtliche Parameter, die einen Ein- 
. f lufi auf die Taktung haben, bestimmen diesen einen globalen 
Takt. Beispielsweise konnen solche Parameter eine Temperatur- 
bestimmung, eine Energiereservemessung von Batterien., etc. 

25 sein. 

Insbesondere kann ein bestimmender Parameter die maximale 
Ausfuhrungsf requenz der langsamsten Konf iguration sein, die 
sich abhangig von. einer PAE-Konf iguration beziehungsweise ei- 
30 ner Konf iguration einer Gruppe von PAEs ergibt. Es wurde er- 
kannt, dass insbesondere im Bussignaltransf er begrenzten An- 
wendungen Konf igurationen unterschiedliche Maximalf requenzen 
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aufweisen konnen, weil unterschiedliche Konf igurationen un- 
terschiedlich viele PAEs iiber unterschiedlich lange Strecken 
von Busverbindungen umfassen konnen. Konf igurationen konnen 
unterschiedliche Maximalf requenzen aufweisen, wie z.B. von 
5 FPGAs bekannt, die von der jeweiligen Funktion der PAEs und 
insbesondere von den Langen von Busverbindungen abhangen. Die 
langsamste Konf iguration stellt dann sicher, dass der ordent- 
liche Betrieb auch dieser Konf iguration sichergestellt ist 
und verringert zugleich den Energiebedarf aller anderen Kon- 

10 f igurationen, was insbesondere dann vorteilhaft ist, wenn un- 
terschiedliche Teile der Datenverarbeitung, wie sie durch die 
anderen Konf igurationen, die gegebenenf alls mit hoheren Takt- 
frequenzen laufen wiirden, nicht vor der langsamsten Konfigu- 
ration benotigt wiirden, Auch in Fallen, in denen absolut si- 

15 cher gewahrleistet sein muss, dass ordnungsgemalier Betrieb 
erfolgt, ist oftmals der gegebenenfalls nur geringe Perfor- 
manceverlust durch Heruntertaktung anderer Konf igurationen, 
die per se schneller laufen konnten, ohne weiteres hinnehm- 
bar . 

20 

In einer optimierten Ausfiihrung wird die Frequenz nur den 
Konf igurationen angepasst, die aktuell auf einer VPU ausge- 
fuhrt werden f mit anderen Worten kann die globale Frequenz 
mit jeder Konf iguration neu eingestellt/konf iguriert werden. 

25 

In einer erweiterten Ausfiihrung kann sodann der Takt global, 
als auch wie bereits beschrieben fur.jedes konf igurierbare 
Element einzeln konf iguriert werden. 

30 Es sei erwahnt, dass verschiedene Varianten einzeln oder in 
Kombiriation moglich sind. Um Naheres beispielhaft zu offenba- 
ren, wird im Folgenden, ohne dass dies zwingend der Fall sein 
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miisste, davon ausgegangen, dass der Takt bei jeder PAE ein- 
zeln gesteuert werden kann. Dann ergeben sich beispielsweise 
folgende Moglichkeiten: 

5 a) Gesteuerte Takt An- und Abschaltung 

Bevorzugt ist der Verarbeitungstakt von PAEs abgeschaltet, 
das heiflt die PAEs arbeiten nur im Bedarfsfall, wobei die 
Taktfreischaltung, also das Aktivschalten der PAE beispiels- 
weise unter Vorliegen zumindest einer der folgenden Bedingun- 

10 gen erfolgen kann, namlich wenn 

gultige Daten anliegen; das Ergebnis der vorhergehenden Bere- 
chung abgenommen wurde; aufgrund eines oder mehrerer Trigger- 
signale; aufgrund einer erwarteten oder gultigen Zeitmarke, 
vergleiche DE 101 10 530.4 (PACT18) . 

15 Dabei kann jede einzelne Bedingung entweder einzeln herange- 
zogen werden, um die Taktfreischaltung zu bewirken, oder in 
Verknupfung mit anderen Bedingungen, wobei anhand der logi- 
schen Verknupfung der Bedingungen die Taktfreischaltung be- 
rechnet wird. Dass es mc)glich ist, wahrend eines abgeschalte- 

20 ten Taktes die PAEs in einen stromsparenden Betriebsmodus zu 
versetzen, beispielsweise mit zusatzlich teilweise abgeschal- 
teter oder verringerter Stromversorgung, beziehungsweise, 
sollte es aus anderen Griinden- erforderlich sein, extrem weit 
herabgesetzten Schlaf takten, sei erwahnt. • 

25 

b) Unterschiedliche Frequenzen je" PAE 
Aus PCT/DE 97/02949 ( PACT02/PCT) , PCT/DE 97/02998 
(PACT04/PCT) , PCT/DE 00/01869 (PACT13/PCT) sind Technologien 
zur Steuerung von sequentiellen Ablaufen in VPUs bekannt. In 
30 PCT/DE 97/02998 (PACT04/PCT) werden spezielle Sequenzer auf- 
' gebaut (SWTs) , die eine Menge von PAEs ansteueren und fur de- 
ren (Re-) Konf iguration verantwortlich sind. Die 
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(Re) Konfiguration wird durch Statussignale die von den PAEs 
generiert werden (Trigger) und an die SWTs weitergeleitet 
werden gesteuert, und zwar dadurch, daft die SWT auf die Trig- 
ger reagiert und die entsprechende Fortsetzung einer Sequenz 

5 von den Triggern abhangig macht. 

In PCT/DE 97/02949 (PACT02/PCT) ist den einzelnen PAEs je- 
weils ein kleiner Speicher fiir deren Konfiguration zugeord- 
net. Ein Sequenzer durchlauft den Speicher und adressiert die 
einzelnen Konf igurationen. Der Sequenzer wird durch Trigger 

10 und/oder dent Status seiner. PAE (in die er beispielsweise in- 
tegriert ist) gesteuert. 

Wahrend der Datenverarbeitung ist es nunmehr moglich, daft un- 
terschiedliche Sequenzer in unterschiedichen PAEs eine unter- 
schiedliche Menge an Operationen pro iibertragenem Datenpaket 

15 durchzufuhren haben (vgl. DE 101 39 170.6 (PACT11), DE 101 42 
903.7 (PACTlla), DE 101 44 732.9 (PACTllb) f DE 101 45 792.8 
(PACTllc), DE 101 54 260.7 (PACTlld), DE 102. 07 225.6 
(PACTlle), PCT/DE 00/01869 (PACT13/PCT) ) . Dies sei am Bei- 
spiel einer Konfiguration beschrieben, bei welcher 3 Sequen- 

20 zer mit der B'earbeitung eines Datenpaketes befasst sind und 
eine unterschiedliche Anzahl von Operationen zur Datenpaket- 
verarbeitung benotigen. Beispiel: 

• Sequenzer 1 (Seql) benotigt 10 Operationen urn ein Daten- 
paket zu verarbeiten 

25' Sequenzer 2 (Seq2) benotigt 5 Operationen urn ein Daten- 

paket zu verarbeiten 

• Sequenzer 3 (Seq3) benotigt 20 Operationen urn ein Daten- 
paket zu verarbeiten 

Um ein optimales Arbeits^/Stromverbrauchsverhaltnis zu erhal- 
30 ten, waren die einzelnen Sequenzer wie folg.t zu takten: Fmax 

= F Se q2 / 4 = Fseql /2 = F Se q3 
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oder bei einer maximalen Arbeitsf requenz von beispielsweise 
100MHz: Fseqi = 50MHz, F Seq 2 = 25MHz, F Seq 3 = 100MHz 

Es wird als besonders vorgeschlagen, je PAE und/oder Gruppe 
5 von PAEs unterschiedliche Taktquellen zu verwenden. Dazu kon- 
nen beispielsweise verschiedene Techniken einzeln oder ge- 
meinsam angewendet werden: 

1) Individuell pro PAE programmierbare Taktteiler, die ausge- 
hend von einem oder mehreren gemeinsamen Basistakten ein je- 

10 weils individuell konf igurierbares Teilerverhaltnis errnogli- 
chen. 

2) Individuell pro PAE programmierbare Taktvervielf acher 
(PLLs), die ausgehend von einem oder mehreren gemeinsamen Ba- 
sistakten ein jeweils individuell konf igurierbares Teilerver- 

15 haltnis ermoglichen. 

3) Ableitung des jeweiligen PAE-Taktes aus dem Datenstrom der 
jeweils zu verarbeitenden Daten, z.B. durch Oversampling. 

Ein Ausftihrungsbeispiel mit unterschiedlicheri Algorithmen ist 
20 in Figur 1 dargestellt. 

c) Konf igurat ions takt 

Eine Optimierung des Energieverbrauches wird auch dadurch be- 
gunstigt, dass die Schaltungsteile, die zur Durchfuhrung ei- 

25 ner Konf iguration notwendig sind, selektiv getaktet werden, 
d.h. es wird vorgeschlagen, je adressierter PAE zu takten 
und/oder den Takt jener Schaltungsteile, die zur Durchfuhrung 
einer Konf iguration beziehungsweise Rekonf iguration erforder- 
lich sind, vollstandig abzuschalten, wenn keine Konf iguration 

30 beziehungsweise Rekonfiguration durchgefuhrt wird und/oder 
statische Register zu verwenden. 
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In besonderen Ausgestaltungen kann die Arbeitsf requenz der 
PAEs oder Gruppen von PAEs von unterschiedlichen und/oder 
weiteren Faktoren abhangig gemacht werden. Es sei nachfolgend 
beispielhaft folgendes aufgefiihrt: 

5 

1 . Temperaturmessung 

Erreicht die Arbeitstemperatur bestimmte Schwellwerte, wird 
der Arbeitstakt entsprechend reduziert. Gegebenenf alls kann 
die Reduktion selektiv erfolgen, indem zunachst jene PAEs mit 
10 einem geringeren Takt betrieben werden, die den irrelevante- 
sten Verlust an Perf ormance darstellen. 

In einer besonders bevorzugten Ausgestaltung konnen mehrere 
Temperaturmessung in unterschiedlichen Regionen durchgefiihrt 
werden und die Taktung jeweils lokal angepasst werden. 

15 

2. Pufferfiillstande 

Aus DE 102 06 653.1 (PACT15) , DE 102 07 224 .8 (PACTlSa) , 
(PACTlSb) sind IO-FIFOs (Eingangs-Ausgangs-First-In-First- 
Out-Schaltkreise) bekannt, die periphere Datentransf ers von 

20 der Datenverarbeitung innerhalb einer VPU entkoppeln. Bei- 
spielsweise kann ein Puffer fur Eingangsdaten (Input-Buffer) 
und/oder ein Puffer fur Ausgangsdaten (Output-Buffer) imple- 
mentiert sein. Eine besonders effiziente Gro/ie zur Taktfre- 
quenzbestimmung kann beispielsweise durch den Fullgrad der 

25 jeweiligen Daten-Puffer bestimmt werden. Beispielsweise kon- 
nen folgende Effekte. und Wirkungen auftreten: 
a) .Ein Input-Buffer ist weitgehend voll und/oder der Fullgrad 
steigt stark an: Erhohung der Taktung, urn die Abarbeitung zu. 
beschleunigen . 

30 b) Ein Input-Buffer ist weitgehend leer und/oder der Fullgrad 
sinkt stark an: Verringerung der Taktung, um die Abarbeitung 
zu verlangsamen. 
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c) Ein Output-Buffer ist weitgehend voll und/oder der Fiill- 
grad steigt stark an: Verringerung der Taktung, urn die Abar- 
beitung zu verlangsamen. 

d) Ein Output-Buffer ist weitgehend leer und/oder der Full- 
5 grad sinkt stark an: Erhohung der Taktung, um die Abarbei- 

tung zu beschleunigen. 

Je nach Applikation und System konnen entsprechend geeignete 
Kombinationen angewendet werden. 

10 Es sei darauf hingewiesen, dass eine derartige Taktf requenz- 
bestimmung implementierbar ist, wenn ein Fullgradbestimmungs- 
mittel fur einen Puffer, insbesonders einen Eingangs- 
und/oder Ausgangspuf f er, alternativ aber auch Zwischenpuf fer 
innerhalb eines VPU-Arrays, vorgesehen ist und dieses Full- 

15 graderfassungsmittel mit einem Taktvorgabemittel zur Vorgabe 
einer Logikzellentaktung verbunden ist, damit dieses die Lo- 
gikzellentaktung im Ansprechen auf den Puf f erftillgrad veran- 
dern kann. 

20 

3. Batteriezustand 

Fur mobile Gerate ist ein sorgsamer Umgang mit der Stromver- 
sorgung z.B. Batterie zwingend erf orderlich. Abhangig von der 
Energiereserve, die nach bestehenden Methoden entsprechend 
25 des Stand der Technik bestimmt werden kann, wird die Frequenz 
von PAEs und/oder Gruppen von PAEs bestimmt, insbesondere bei 
geringer Energiereserve reduziert. 

Es ist moglich, neben oder zusatzlich zur Optimierung der Da- 
30 tenvefarbeitungstaktung auch eine Optimierung des Datentrans- 
fers respektive des Verhaltnisses zwischen Datentransf er und 
Datenverarbeitung zu erreichen. 
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In einer besonderen Ausgestaltung konnen die beschriebenen 
Taktsteuerungen von PAEs derart erweitert werden, dass - bei- 
spielsweise unter Verwendung einer sequenzerahnlichen An- 
steuerung und eines geeigneten Registersatzes - mehrere be- 

5 vorzugt unterschiedliche Konf igurationsworte in mehreren Tak- 
ten nacheinander ausgefuhrt werden konnen. Dazu kann den Kon- 
figurationsregistern und/oder einem - eventuell auch abgekop- 
pelten und separat implementieren - Konf igurationsspeicher 
(vgl. DE 102 06 653.1 (PACT15), DE 102 07 224.8 (PACT15a) , 

10 PACT15b) ein Sequenzer zugeordnet werden, der eine Anzahl von 
Konfigurationseintragen sequentiell abarbeitet. Der Sequenzer 
kann als Mikrokontroller ausgestaltet sein. Insbesondere kann 
der Sequenzer in seiner Funktion programmier- 
bar/konf igurierbar sein, wie beispielsweise der Baustein 

15 EPS448 von Altera [ALTERA Data Book 1993] . Mogliche Ausge- 
staltungen derartiger PAEs sind beispielsweise in den Pa- 
. tentanmeldungen PCT/DE 97/02949 (PACT02/PCT) , PCT/DE 97/02998 
(PACT04/PCT) , PCT/DE .00/01869 (PACT13/PCT) , DE 101 10 530.4 
(PACT18 ) , DE 102 06 6.53.1 (PACT15) , DE 102 07 224.8 

20 (PACTlSa), PACT15b beschrieben, die zu Of f enbarungszwecken 
vollumf anglich eingegliedert werden. 

Es wird fur das Nachfolgende zunachst davon ausgegangen, dass 
mehrere Konf igurationsworte zu einer Konf igurat ion (PAK- 
KEDCONF) zusammengefaftt und auf eine PAE konfiguriert werden. 

25 Die PACKEDCONF wird derart abgearbeitet , dass die einzelnen 
Konf igurationsworte zeitlich nacheinander ausgefuhrt werden. 
Der Datenaustausch und/oder Statusaustausch zwischen den ein- 
zelnen zeitlichen Konf igurationen erfolgt durch eine geeigne- 
te Datenriickkopplung in den PAEs, beispielsweise durch einen 

30 geeigneten Registersatz und/oder ein anderes Daten- und/oder 
Statusaustauschmittel, wie geeignete Speicher und derglei- 
chen . 
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Dieses Verfahren erlaubt ein unterschiedliches Timing fur 
PAEs und Bussysteme. Wahrend PAEs beispielsweise mit sehr ho- 
hen Taktraten Daten verarbeiten, werden Operanden und/oder 
5 Ergebnisse nur mit einem Bruchteil der Taktrate der PAEs uber 
einen Bus iibertragen. Die Ubertragungszeit uber den Bus kann 
entsprechend langer sein. 

Es ist bevorzugt, wenn nicht nur die PAEs oder andere Logi- 
keinheiten in einem konf igurierbaren und/oder rekonf igurier- 

10 baren Baustein mit unterschiedlicher Geschwindigkeit taktbar 
sind, sondern auch eine unterschiedliche Taktung von Teilen 
eines Bussystems vorgesehen wird. Dabei .ist es moglich, ent- 
weder mehrere parallele Busse vorzusehen, die unterschiedlich 
schnell getaktet werden, etwa einen Bus, der besonders hoch 

15 getaktet wird, urn eine hochperf ormante Verbindung vorzusehen, 
parallel zu einem niedriger getaktetea Bus, der eine strom- 
sparende Verbindung vorsieht. Die hochgetakte Verbindung kann 
dann verwendet werden, wenn langere Signalwege ausgeglichen 
werden mussen, oder wenn eng beieinanderliegende PAEs mit ho- 

20 her Frequenz arbeiten und demgemaB auch mit hoher Frequenz 

Daten austauschen mussen, um hier uber kurze Entf ernungen, in 
welchen die Latenzzeit eine allenfalls geringe Rolle spielt, 
eine gute Ubertragung vorzusehen. Es wird somitin einer mog- 
lichen Ausgestaltung vorgeschlagen., dass eine Anzahl lokal 

25 zueinander angeordneter PAEs zu einer Gruppe zusammengef aiit 
mit einer hohen Frequenz ggf. auch sequentiell arbeitet und 
lokale und entsprechend kurze Bussysteme der Datenverarbei- 
tungsrate der Gruppe entsprechend hoch getaktet werden, wah- 
rend die Operanden zufuhrenden oder Ergebnisse abfuhrenden 

30 Bussysteme langsamere Takt- und Datentransf erraten aufweisen. 
Alternativ ware es moglich, innerhalb einer Gruppe aus PAEs 
zu Zwecken der Energieverbrauchsoptimierung eine langsame 
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Taktung vorzunehmen und Daten mit hoher Geschwindigkeit zuzu- 
ftihren, etwa wenn eine Vielzahl von einstromenden Daten mit 
nur geringem Operationsaufwand, also niedrigen Taktzahlen ge- 
arbeitet werden kann. 

5 

Neben der Moglichkeit Bussysteme vorzusehen, die mit unter- 
schiedlicher Frequenz getaktet werden, ist es auch moglich, 
iiberhaupt mehrere unabhangig voneinander betreibbare Bussy- 
steme vorzusehen und dann die PAEs multiplexartig wie erfor- 

10 derlich auf zuschalten. Dies ermoglicht es schon fur sich ge- 
nommen, und unabhangig von der immer noch gegebenen Moglich- 
keit einer unterschiedlichen Taktung unterschiedlicher Bussy- 
steme oder unterschiedlicher Bussystemteile, rekonf igurierba- 
re Bausteine besonders effizient im Ressourcenmultiplexing zu 

15 betreiben. Es ist dabei moglich, unterschiedlichen Ressourcen 
nach unterschiedlichen Multiplexingverf ahren unterschiedliche 
Konfigurationen zuzuteilen. 

Insbesondere kann eine Gruppe von PAEs als Prozessor entspre- 
20 chend PCT/DE 00/01869 (PACT13/PCT) ausgestaltet sein.. 

In den nachf olgenden- Ausfiihrungen werden beispielsweise da- 
tenverarbeitenden PAEs mittels eines Zeitmultiplexings ver- 
25 schiedenen Konfigurationen zugewiesen, wahrend Bussysteme 

mittels eines Raummultiplexings den verschiedenen Konfigura- 
tionen zugewiesen werden. 

Bei der Zuweisung von Ressourcen, das heiBt der vom Compiler 
30 oder einer ahnlichen Einheit vorzunehmenden Zuweisung von 

Aufgaben an PAEs beziehungsweise. eine Guppe von PAEs kann das 
gegebene Feld dann betrachtet werden als ein Feld der n- 
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fachen Grofie und es konnen Codeteile in dieses urn den Faktor 
n virtuell vergrofierte Feld an Ressourcen iibertragen werden, 
ohne dass Probleme auftreten, vor allem dann, wenn Codeteile 
so erteilt werden, dass in eine multiplexartig verwendete PAE 
5 keine voneinander abhangigen Codeteile einkonf iguriert werden 
mussen. 

In der bisherigen Betrachtung bestand eine PACKEDCONF aus 
mindestens einem Konf igurationswort Oder einer Biindelung von 
10 Konf igurationsworten fur PAEs, die zu einer einzigen Applika- 
tion gehoren. Mit anderen Worten wurden in PACKEDCONF nur zu- 
sammengehorende Konf igurationsworte zusammengefafit . 

In einer erweiterten Ausgestaltung werden mindestens eines 
15 oder mehrere Konf igurationsworte je unterschiedlicher Konfi- 
gurationen in eine PACKEDCONF aufgenommen, derart dass je- 
weils das Konf igurationswort oder die Konf igurationsworte, 
die zu einer Konf iguration zusammengehoren als Konfigura- 
tions-Gruppe zusanunengeschlossen sind und sodann die entste- 
20 henden Konf igurations-Gruppen in das PACKEDCONF zusammenge- 
falit werden. 

Die einzelnen Konf igurations-Gruppen. konnen zeitlich nachein- 
ander ausgefuhrt werden, also in einem Zeitmultiplexing' mit 
25 einer zeitscheibenartigen Zuweisung. Dadurch entsteht ein 

Zeitmultiplexing unterschiedlicher Konf igurations-Gruppen auf 
einer PAE. Das Konf igurationswort oder die Konf igurationworte 
innerhalb einer Konf igurations-Gruppe konnen ebenfalls wie 
vorstehend beschrieben zeitlich nacheinander ausgefuhrt. 

30 

Den Konf igurationsregistern und/oder einem - eventuell auch 
abgekoppelten und separat implementieren - Konf igurations- 
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speicher (vgl. DE 102 06 653.1 (PACT15) , DE 102 07 224.8 
(PACTlSa), PACT15b) werden Multiplexer zugeordnet, die eine 
der Konf igurations-Gruppen auswahlen. In einer erweiterten 
Ausfuhrung kann weiterhin ein Sequenzer (wie bereits be- 
5 schrieben) zugeordnet sein, der die sequentielle Abarbeitung 
von Konf igurationsworten innerhalb von Konf igurations-Gruppen 
ermoglicht . 

Durch die Multiplexer und optionalem Sequenzer kann eine Res- 
10 source (PAE) in einem Zeitmultiplexverf ahren mehreren unter- 
schiedlichen Konf igurationen zugeordnet werden. 
Unterschiedliche Ressourcen konnen die jeweils anzuwendende 
Konfigurations-Gruppe untereinander synchronisieren, bei- 
spielsweise durch (jbertragung einer Konfigurations- 
15 Gruppennummer oder eines Zeigers. 

Die Ausfuhrung der Konf igurations-Gruppen kann linear hinter- 
einander und/oder zyklisch erfolgen. Eine Priorisierbarkeit 
sei erwahnt. Besonders hervorzuheben ist, dass hierbei unter- 

20 schiedliche Sequenzen in einem einzigen Prozessorelement ab- 
gearbeitet werden konnen und dass dazu zugleich unterschied- 
liche Bussysteme vorgesehen sein konnen, sodass mit dem Auf- 
bau einer Busverbindung, die aufgrund der langen Ubertra- 
gungswege andauern kann, keine Zeit vergeudet wird. Wenn eine 

25 PAE ihre erste Konf iguration einem ersten Bussystem zuordnet 
und bei Ausfuhrung der ersten Konfiguraton an dieses ankop- 
pelt, kann sie, wenn raumliches Multiplexing fur das Bussy- 
stem moglich ist, in einer zweiten Konf iguration auf ein da- 
von verschiedenes oder partiell verschiedenes Bussystem auf- 

30 koppeln beziehungsweise daran ankoppeln. 
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Die Ausfuhrung einer Konf igurations-Gruppe, jede Konfigura- 
tipns-Gruppe bestehend aus einem oder mehreren Konfigurati- 
onsworten, Icann von dem Eintreffen einer Ausfuhrungsf reigabe 
durch Daten und/oder Triggern und/oder einer Ausfuhrungsf rei- 
5 gabebedingung abhangig gemacht werden. 

1st die Ausf uhrungsf reigabe (-bedingung) fur eine Konfigura- 
tions-Gruppe nicht gegeben, kann entweder auf die Ausfiih- 
rungsf reigabe (-bedingung) gewartet werden oder mit der Aus- 

10 fuhrung einer nachf olgenden Konf igurations-Gruppe fortgefah- 
ren werden. Wahrend des Wartens auf eine Ausfuhrungsf reiga- 
be (-bedingung) gehen die PAEs bevorzugt in einen stromsparen- 
den Betr'iebsmodus, beispielsweise mit abgeschaltetem Takt 
(Gated Clock) und/oder teilweise abgeschalteter oder verrin- 

15 gerter Stromversorgung. Kann keine Konf igurations-Gruppe ak- 
tiviert werden, gehen PAEs bevorzugt ebenfalls in einen 
stromsparenden Betriebsmodus wie vorerwahnt. 

Die Speicherung der PACKEDCONF kann unter Verwendung eines 
20 Ringspeichers oder anderer Speicher- beziehungsweise Regi- 

stermittel erfolgen, wobei die Verwendung eines Ringspeichers 
zur Folge hat, dass nach Ausfuhrung des letzten Eintrages 
wieder mit der Ausfuhrung des erstens begonnen werden kann 
(vgl. PCT/DE 97/02998 (PACT04/PCT) ) - Es sei erwahnt, dass in- 
25 nerhalb der PACKEDCONF und/oder einer Konf igurationsgruppe 

auch direkt und/oder indirekt und/oder jeweils bedingt in ei- 
ne besondere Ausfuhrung gesprungen werden kann. 

In einem bevorzugten Verfahren konnen PAEs zur entsprechenden 
30 zeitgemultiplexten Abarbeitung von Konf igurationen ausgear- 
beitet sein. Die Anzahl der Bussysteme zwischen den PAEs wird 
■ derart erhoht, dass fur eine ausreichende Anzahl von Konfigu- 
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rations-Gruppen ausreichencle Ressourcen zur Verfiigung stehen. 
Mit anderen Worten arbeiten die datenverarbeitenden PAEs in 
einem Zeitmultiplexverf ahren, wahrend die datenubertragenden 
und/oder datenspeichernden Ressourcen in hinreichender Menge 
5 zur Verfiigung gestellt sind. 

Dies entspricht einer Art Raummultiplexing, wobei ein erstes 
Bussystem einer ersten zeitweise abgearbeiteten Konf iguration 
zugeordnet ist und ein zweites, raumlich getrennt von diesem 
10 verlaufendes beziehungsweise gefiihrtes Bussystem einer weite- 
ren Konf iguration zugeordnet ist. 

Es ist zugleich und/oder alternativ moglich, dass auch die 
Bussysteme ganz oder partiell im Zeitmultiplexing betrieben 

15 werden und sich mehrere Konf igurationsgruppe ein Bussystem 
teilen. Hierbei kann vorgesehen sein, dass jede Konf igurati- 
onsgruppe seine Daten beispielsweise als Datenpaket uber- 
tragt, welchem eine Konf igurations-gruppenID zugeordnet ist 
(vergleiche APID in DE 102 06 653.1 (PACT15) , DE 102 07 224.8 

20 (PACTlSa), PACTlSb) . Es kann dann vorgesehen sein, die je- 
weils ubertragenen Datenpakete anhand der ihnen zugeordneten 
Identif ikationsdaten abzuspeichern, zu sortieren und zwar bei 
Bedarf und zur Abstimmung der IDs zwischen unterschiedlichen 
Bussen. 

25 

In einem erweiterten Verfahren konnen auch Speicherquelleri 
zeitlich gemultiplext werden, beispielsweise indem mehrere 
Segmente implementiert sind und/oder bei einem Wechsel der 
Konf igurations-Gruppe der oder die entsprechenden Speicher 
30 entsprechend PCT/DE 97/02998 (PACT04/PCT) und/oder PCT/DE 
00/018 69 (PACT13/PCT) in einen anderen ggf . auch externen 
Speicher geschrieben oder aus diesem geladen werden. Insbe- 
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sondere die Verfahren nach DE 102 06 653.1 (PACT15), DE 102 
07 224.8 (PACT15a) , PACT15b konnen Anwendung finden (bei- 
spielsweise MMU paging und/oder APID) 

5 Als weitere Moglichkeit zur Ressourcenschonung sei die Anpas- 
sung der Betriebsspannung an den Takt erwahnt. 
Halbleiterprozesse lassen typischerweise hohere Taktfrequen- 
zen zu, wenn sie bei hoheren Betriebsspannungen betrieben 
werden. Allerdings wird dadurch erheblich mehr Strom ver- 
10 braucht und ggf . verringert sich auch die Lebensdauer eines 
Halbleiters . 

Ein optimaler Komproraiss kann erreicht werden, indem die 
Spannungsversorgung von der Taktfrequenz abhangig "gemacht 
wird. Beispielsweise kann bei geringen Taktf requenzen mit ge- 
15 ringer Versorgungsspannung gearbeitet werden. Mit ansteigen- 
. den Taktf requenzen wird die Versorgungsspannung ebenfalls 
(vorzugsweise bis zu einem. def inierten Maximum) erhoht. 

Die Erfindung wird im folgenden noch weiter beispielhaft dar- 
20 gestellt unter Bezugnahme auf die beigefugte Zeichnung. Es . 
sei erwahnt, dass diese beispielhafte Umschreibung nicht li- 
. mitierend ist und im Einzelfall in unterschiedlichen Figuren 
identische oder ahnliche Einheiten mit unterschiedlichen Be- 
zugszeichen belegt sein konnen. 

25 

Figur 1 zeigt beispielhaft eine rekonf igurierbare Datenverar- 
beitungseinrichtung (VPU) (0101) . Einem Array aus unabhangig 
voneinander konf igurierbaren und rekonf igurierbaren PAEs 
(0102) ist eine Konf igurationseinheit (CT, 0103) iibergeordnet 
30 zur Steuerung und Durchfuhrung der Konf iguration und Rekonfi- 
guration. Hierzu sei besonders auf die verschiedenen Anmel- 
dungen des Anmelders und den Of f enbarungsgehalt der einlei- 
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tend unter Bezug genommenen Schriften und Technologien ver- 
wiesen. Der Datenverarbeitungseinrichtung ist weiterhin ein 
Zentraltaktgenerator (0104) zugeordnet. Die Taktrate des Zen- 
traltaktgenerator kann in einer moglichen Ausgestaltnug von 
5 der Konfigurationseinheit 0103 vorgegeben werden. Die Taktra- 
te jeder PAE und/oder Gruppen von PAEs und deren Busverbin- 
dungen kann in einer moglichen Ausgestaltung ebenfalls von 
der Konfigurationseinheit 0103 vorgegeben werden. 

10 Nach Fig. 2 speist die Konfigurationseinheit 0103 iiber eine 
Konf igurationsleitung 0103a konf igurierende Daten in jeweili- 
ge Zellen 2, von welchen nur eine beispielhaft dargestellt 
ist. Weiter wird an die Zelle 0102 das Taktsignal des zentra- 
len Taktgenerators 0104 iiber eine Taktleitung 0104a gespeist. 

15 Die rekonf igurierbare Zelle 0102 kommuniziert iiber einen Da- 
tenbuseingang 0205a und -ausgang 0205b mit anderen Zellen und 
weist weiter eine datenverarbeitende Einheit beispielsweise 
eine arithmetische Logikeinheit ALU 0206 auf, sowie bevorzugt 
einen internen Datenspeicher. 0207 und einen Konf igurations- 

20 speicher 0208 , in welchem die konf igurierenden Befehle aus 
der Konfigurationseinheit 0103 iiber einen Konf igurationsbe- 
f ehlextraktor 0209 eingespeist werden, urn im Ansprechen dar- 
auf die datenverarbeitende Einheit beispielsweise ALU 0206 zu 
konf igurieren. Der Konf igurationsextraktor 0209 ist weiter 

25 mit einem Frequenzteilungs/ vervielf achungsf aktorvorgabeein- 
gang 0210a eines Frequenzteilers/Ferquenzvervielf achers 0210 
verbunden, welcher dazu ausgebildet ist, das Taktsignal' des 
zentralen Taktgenerators 0104 auf der Taktleitung 0104a ent- 
sprechend einem iiber den Eingang 0210a vorgegebenen Taktver- 

30 haltnisses zu teilen oder zu vervielf achen und. das Taktsignal 
an die datenverarbeitende Einheit, beispielsweise die arith- 
metische Logikeinheit ALU 0206 und gegebenenf alls weitere 
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Einheiten der rekonf igurierbaren Zelle 0102 uber eine Leitung 
0211 zu speisen. 0210 kann durch eine optionale Datenbusiiber- 
wachungsschaltung 0212 derart angesteuert werden, dass die 
Frequenz in Abhangigkeit des Empfangs oder Versendens von Da- 

5 ten gesteuert wird. 

Optional kann weiterhin ein Multiplexer 0213 zur Auswahl un- 
terschiedlicher Konf igurationen und/oder Konf igurations- 
Gruppen in Abhangigkeit von 0212 integriert sein. Der Mult- 
plexer kann weiterhin optional durch einen Sequenzer 0214 an- 

10 gesteuert werden, urn eine sequentielle Datenverarbeitung zu 
ermoglichen. Insbesondere dafur konnen Zwischenergebnisse in 
dem Datenspeicher 0207 verwaltet werden. 

Wahrend die allgemeine Konf iguration der Zelle bereits zum 
15 Teil in den einleitend erwahnten Anmeldungen des Anmelders 
beschrieben wurde, ist wenigstens die vorliegend beschriebene 
Taktteilungsanordnung, die zugehorige Beschaltung und die Op- 
timierung ihres Betriebs neu, wobei darauf hingewiesen wird, 
dass diese jeweils mit erf orderlichen Hardwareveranderungen 
20 einhergehen konnen und werden. 

Die Gesamt-Anordnung und insbesondere die Konf igurationsein- 
heit 0103 ist so gebildet, dass mit einem konf igurierenden 
Signal, mit welchem ein Konf igurationswort uber die Konfigu- 

25 rationsleitung 0103a uber den Konf igurationswortextraktor 
0209 an die datenverarbeitende Einheit 0206 bzw. den vor- 
und/oder nach- und/oder zugeordneten Speicher 0208 gespeist 
wird, auch ein Taktteilungs/vervielf achungssignal ausgesen- 
, det, von dem Konf igurationswortextraktor 0209 extrahiert und 

30 an den Frequenzteiler/-vervielf acher 0210 gesendet werden 
kann, damit dieser die datenverarbeitende Einheit 0206 und 
gegebenenfalls noch andere Einheiten im Ansprechen darauf 
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takten kann. Es sei darauf hingewiesen, dass an Stelle der 
Einheit 0209 auch andere Moglichkeiten bestehen, im Anspre- 
chen auf ein Eingabesignal an die Zelle die Taktung einer 
einzelnen datenverarbeitende Einheit 0206 unter Bezugnahme 
5 auf eine zentrale Takteinheit 0104 zu variieren, beispiels- 
weise uber die Datenbusuberwachungsschaltung 0212. 

Ein Gesamtfeld aller rekonf igurierbaren Logikeinheiten 0102 
kann unter Verwendung der vorstehend beschriebenen Ausbil- 
10 dung, aber gegebenenfalls auch unter anderer Implementierung 
der Einheiten betrieben werden, wie es nur beispielhaft mit 
Bezug auf Fig. 3 und 4 beschrieben werden wird: 

Nach Fig. 3a ist beispielsweise ein 3x3-Feld rekonf igurierba- 

15 rer Zellen so konf iguriert , dass eine erste Zelle 0102a zur 
Auswertung eines Eingang/Ausgang-Signals dient. Die Zellen 
0102b, ,0102c werden gegenwartig nicht benotigt und sind dem~ 
gemaft als nicht konf iguriert (n.c.) bezeichnet. Die Zellen 
0102d bis 0102i bilden zusaitmien eine Gruppe, mit der eine 

20 komplexe arithmetische Operation ausgefuhrt wird, wobei in 
Zelle 0102d eine Addition, in Zelle 0102e eine Subtraktion, 
in Zelle 0102f eine . Multiplication erfolgt, in Zelle 0102g 
eine Schleife durchlaufen wird, innerhalb von welcher eine 
Mehr.f achaddition vorgenommen wird, in Zelle 0102h eine Divi- 

25 sion erfolgt und in Zelle 0102i wiederum eine Addition. Die 
Zellen 0102d bis 0102i sind in der durch strichpunktierte Li- 
nien angedeuteten Gruppe 0301 so miteinander verbunden, dass 
Daten sequentiell und pipelineartig von den Zellen abgearbei- 
tet werden. Die Operationen innerhalb der Zellen 0102d und. 

30 0102e laufen in unterschiedlich vielen Taktzyklen ab, wie in 
Tabelle Figur 3b in der zweiten Reihe angedeutet ist. Dort 
ist die Anzahl der Taktzyklen angegeben und es ist ersicht- 
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lich, dass eine Addition oder Subtraction in einem Taktzyklus 
ausgefuhrt werden kann, die Division aber 32 Taktzyklen be- 
notigt. In der dritten Zeile der Tabelle von Figur 3b ist nun 
angegeben, welcher Wert dem Frequenzteiler jeder Zelle zuge- 

5 ordnet ist, um eine optimale Energienutzung bei doch konstant 
bleibendem Datendurchsatz durch die Zelle zu erreichen. Nur 
die Zelle, in welcher die Division stattfindet, wird mit 
hSchstem Takt betrieben; hier ist das Taktverhaltnis 1. Diese 
Zelle benotigt fur die ihr zugewiesene Operation am langsten. 

10 Da nur alle 32 Takte ein neues Ergebnis an die die Division 
durchfuhrende Zelle 0102h geliefert werden braucht, sind die 
Zellen 0102d und 0102e um den entsprechenden Faktor 32 lang- 
samer getaktet; das Frequenzteilerverhaltnis fur diese Zellen 
betragt demgemafi 32, wie in Fig. 3b ersichtlich. Die Multi- 

15 plikation, die in zwei Taktzyklen ablauft., besitzt dem hinge- 
gen ein Frequenzteilerverhaltnis 16 und die wiederum aufwen- 
digere Schleife von Zelle 0102g, die in 16 Taktzyklen ab- 
lauft, erhalt nur ein Frequenzteilerverhaltnis von 2 zugewie- 
sen. Diese Taktverhaltnisse sind zunachst bei der Konfigurie- 

20 rung, in der die einzelnen Zellen gruppenweise zusaramenge- 

stellt werden und jeder Zelle innerhalb der Gruppe zugewiesen 
wird, bekannt, da sie vom Compiler bei der Programmcompilie- 
rung bestimmt wurden und konnen demgemaft in die Zelle bei de- 
ren Konf iguration eingegeben werden. In der vierten Reihe von 

25 oben ist angegeben, welche Taktrate sich bei einem Zentralt- 
akt von 256 MHz ergibt. 

Wird die Prozessoreinheit mit den separat taktbaren rekonfi- 
gurierbaren Logikzellen in einer Anwendung betrieben, in der 
30 die Spannung abfallen kann, beispielsweise aufgrund sich er- 
schdpfender Kapazitaten einer Span'nungsversorgung, so kann 
vorgesehen werden, dass beispielsweise bei Abfall der Versor- 
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gungsspannung auf einen kritischen Wert Ul die Gesamtf requenz 
herunter gesetzt wird und es werden dann alle Zellen urn die 
Halfte langsamer getaktet, so dass auch die Divisionszelle 
0102h nur noch mit 128 MHz lauft, wahrend die Zelle 0102d mit 

5 4 MHz getaktet wird. Die Zelle 0102a, die eine mit geringerer 
Prioritat erfolgende Abfrage des Mauszeigers durchfuhrt, wird 
nicht mehr mit 8 MHz getaktet. wie zuvor, sondern nur noch mit 
2 MHz, das heilit, es werden abhangig von der Priorisierung 
bei Spannungsabf all oder unter anderen Umstanden den jeweili- 

10 gen Gruppen unterschiedliche Verlangsamungen je nach Bedeu- 
tung der Aufgabe zugewiesen. 

Steigt dann aus anderen Grunden noch die Temperatur an, kann 
die Warmeerzeugung im Logikzellenfeld durch eine weitere Her- 

15 absetzung der Taktraten der Logikzellen weiter verringert 
werden, wie dies in der letzten Reihe von Fig. 3b angedeutet 
ist. Es versteht sich, dass wahlweise z.B. ein jeweiliger 
einzelner Sensor zur Bestimmung des Zustandes wie der Versor- 
gungsspannung und/oder der Temperatur vorgesehen werden kann, 

20 dessen Sensorsignal konditioniert an die Zellen gespeist wer- 
den kann, eine entsprechende Sensoranordnung jeder Zelle zu- 
geordnet sein kann und/oder gegebenenf alls . auch der Zentralt- 
akt veranderbar ist. 

25 Damit lafit sich ein Prozessorfeld energieoptimal betreiben, 
die erfprderlichen Kiihlleistungen nehmen ab und es ist ein- 
sichtig, dass, da im Regelfall nicht alle Zellen stets mit 
hochster Taktfrequenz betrieben werden konnen- und/oder miis- 
sen, Kuhlkorper und dergleichen entsprechend schwacher dimen- 

30 sioniert werden konnen, was wiederum weitere Kostenvorteile 
. bringt. 
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Es sei erwahnt, dass neben der Abfrage einer Versorgungsspan- 
nung, einer Temperatur, der Priorisierung von Rechnungen und 
dergleichen weitere Zustande taktbestimmend sein konnen. So 
kann beispielsweise ein Hardware- oder Softwareschalter vor- 
5 gesehen werden, mit dem der Benutzer angibt, dass eine nur 
geringe Taktung oder eine hohere Taktung gewunscht ist. Dies 
ermoglicht einen noch sparsameren und gezielten Umgang mit 
der zur Verfugung stehenden Energie. Es kann dabei insbeson- 
dere vorgesehen werden, dass die Zentraltaktrate auf Anforde- 

10 rung eines Benutzers oder auf externe Anforderung insgesamt 
herabgesetzt werden kann, aber die Taktteilerverhaltnisse in- 
nerhalb des Zellarrays nicht verandert werden, um, etwa bei 
Temperaturiiberhohung, das Erfordernis zu vermeiden, alle Zel- 
len neu zu konf igurieren. Oberdies sei darauf hingewiesen, 

15 dass bei der Bestimmung der Taktraten ein Hystereseverhalten 
vorgesehen werden kann, etwa dann, wenn temperaturabhangig 
die Taktfrequenzen verandert werden sollen. 

Figur 4 zeigt nochmals die Datenverarbeitungseinrichtung 
20 (VPU) nach Figur 1. Unterschiedliche Gruppen innerhalb der 
VPU werden mit unterschiedlichen Frequenzen f betrieben, die 
jeweils von einem durch 0104 generierten Frequenznormal n ab- 
geleitet werden. Es soli ausdriicklich erwahnt sein, dass auch 
mehrere Frequenznormale (n x . . .n n ) von mehreren 0104 generiert 
25 und innerhalb einer VPU verwendet werden konnen. 

Figur 5 zeigt ein einfaches Ausfiihrungsbeispiel fur den Be- 
trieb einer PAE nach Figur 2. Ein Datenbus (0205a) liefert 
die Operanden ial und ia2 an eine .ALU (0206), die das Ergeb- 
30 nis der Berechnung oa an 0205b liefert. Die PAE wird nur dann 
aktiv,. d.. h. getaktet und/oder mit Strom versorgt, wenn die 
Datenbusuberwachungsschaltung 0212 die Annahme des vorherigen 
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Ergebnisses oa durch den Empfanger und das Eintreffen der fur 
die Operation erf orderlichen Operanden ial und ia2 erkennt. 
Mit anderen Worten wird die PAE erst dann aktiv, wenn samtli- 
che Arbeitsbedingungen und -erfordernisse erfullt sind. Die 
5 Taktfreischaltung erfolgt durch 0210, die Taktquelle ist 
0104a. 

Figur 6 entspricht Figur 5 mit dem Zusatz, dass ein Sequenzer 
(0214) aktiviert wird, der eine mehrzyklische Konf iguration 

10 (z.B. eine komplexe Berechnung wie z.B. Matrixmultiplikation 
o.a.) steuert. Die Operationen entnimmt er dem Konfigurati- 
onsspeicher oder aus einem Ausschnitt des Konf igurationsspei- 
chers. In dem dargestellten Beispiel werden die Operationen . 
opl, op2, op3, op4, op5 sequentiell ausgefuhrt. Nach Beendi- 

15 gung wird das Ergebnis oa versendet und die PAE muss erneut 
aktiviert werden. 

Der auf dem Datenbus 0205a/b eintretende Datentransf er ist in 
Figur 6a dargestellt. Es sei darauf hingewiesen, dass das Da- 

20 tenrouting uber den Bus in per se bekannter Weise.wie aus an- 
deren Anmeldungen und/oder Verof f entlichungen des vorliegen- 
den Anwenders bekannt, erfolgen kann, das heilit es konnen 
Kollisionsverhinderungen und' Deadlock-Situationen in per se 
bekannter Weise fur jeweils eine Konf iguration verhindert 

25 werden. 

Fur die Ausfuhrung von opl mussen die Operanden ia uber 0205a 
verfiigbar sein (0601), die Datentransf ers fur die restlichen- 
Zyklen konnen prinzipiell undefiniert sein.. 
30 Bevorzugt kann danach 0205;a die nachfolgenden Operanden uber- 
tragen (0602), wozu die Ausfuhrungzeit von op2, op3, op4 r op5 
zur Verfiigung steht und somit eine wesentliche zeitliehe Ent- 
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kopplung eingetreten ist, die die Verwendung von langsameren 
und/oder insbesondere langeren Bussystemen zulafit. 
Alternativ (0603) konnen in einem Zeitmultiplexverf ahren wah- 
rend der Ausfuhrung von op2, op3, op4, op5 Daten anderer Kon- 
5 figurationen iiber dasselbe Bussystem 0205a ubertragen werden. 

Das Ergebnis oa liegt nach op5 auf dem Bus 0205b an (0601), 
die Datentransf ers fur die restlichen Zyklen konnen prinzipi- 
ell undefiniert sein. 

10 Bevorzugt kann die Zeit davor, also wahrend der Ausfuhrung 

von opl, op2, op3, op4 konnte noch zu Obertragung des vorher- 
gehenden Ergebnisses genutzt werden (0602) . Wiederum ist eine 
wesentliche zeitliche Entkopplung eingetreten, die die Ver- 
wendung von langsameren und/oder insbesondere langeren Bussy- 

15 stemen zulaftt. 

Alternativ (0603) konnen in einem Zeitmultiplexverf ahren wah- 
rend der Ausfuhrung von opl, op2, op3, op4 Daten anderer Kon- 
figurationen uber dasselbe Bussystem 0205b ubertragen werden. 
0210 kann eine PLL zur Taktvervielf achung verwenden. Insbe- 

20 sondere kann eine PLL derairt angewendet werden, dass der Ar- 
beit stakt der PAE zur Abarbeitung von opl, op2, op3, op4, op5 
das fiinffache des Bustaktes betragt. In diesem Fall kann sich 
die PAE wie eine PAE ohne Sequenzer mit nur einier (einzykli- 
schen) Konf iguration und demselben Takt wie der Bustakt, ver- 

25 halten. 

Figur 7 entspricht Figur 6 mit. den Zusatz, dass mehr ere Kon- 
f igurations-Gruppen (ga, gb, gc) sich die PAE zeitgemulti- 
plext teilen und jede Gruppe Anschliisse auf ein separater 
30 (Raumgemultiplextes) Bussystem aufweisen (ia/oa, ib/ob, 

ic/oc) . Ein Multiplexer in 0214 selektiert zyklisch die Grup- 
pen ga, gb, gc. Sofern die Datenbusuberwachungsschaltung 0212 
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eine gultige Ausfiihrungsfreigabe (-bedingung) fur eine Konfi- 
gurations-Gruppe generiert, wird die jeweilige Konfigura- 
tions-Gruppe ausgefiihrt, ansonsten kann auf die Ausfiihrungs- 
freigabe (-bedingung) gewartet werden oder bevorzugt eine an- 
5 dere nachste Konf igurations-Gruppe selektiert. Die Konfigura- 
tions-Gruppen konnen zyklisch durchlaufen werden. 
Eine Konf igurations-Gruppe kann mehrere Konf igurationsworte 
beinhalten (ga = {kal, ka2}, gb = {kbl}, gc = {kcl, kc2, 
kc3}). Die Konf igurationsworte konnen durch einen Sequenzer 
10 in 0214 sequentiell ausgefuhrt werden. 

Figur 7a zeigt die Bustransfers des Beispiels nach Figur 7. 
0701 entspricht 0601, 0702 entspricht 0602, 0703 entspricht 
0603. Dabei werden fur jede Gruppe ga, gb, gc ein eigenes 

15 Bussystem verwendet. 

Zusatzlich ist in 0704 ein moglicher Bustransfer unter Ver- 
wendung eines Zeitmultiplexings fur die Bussysteme darge- 
stellt. Die Eingangsdaten samtlicher Gruppen werden uber ein 
Eingangs-Bussystem iibertragen, die Ausgangsdaten samtlicher 

20 Gruppen werden uber ein Ausgangs-Bussystem iibertragen. Die 
undef inierten Zwischenzyklen sind entweder unbenutzt oder 
frei fur andere Datentransf ers . 
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Patentanspruche 

1. Datenverarbeitungseinheit (VPU) mit einem in unterschied- 
lichen Konf igurationszustanden betreibbaren Feld getakte- 
ter Logikzellen (PAEs)' und einem Taktvorgabemittel zur 
Vorgabe einer Logikzellentaktung, dadurch gekennzeichnet , 
dass das Taktvorgabemittel dazu ausgebildet ist, zu- 
standsabhangig an zumindest einer ersten Zelle (PAE) ei- 
nen ersten und an zumindest einer weiteren Zelle einen 
weiteren Takt vorzugeben. 

2. Datenverarbeitungseinheit nach dem vorhergehenden An- 
spruch, dadurch gekennzeichnet, dass das Taktvorgabemit- 
tel dazu ausgebildet ist, den Solltakt fur wenigstens ei- 
ne erste Zelle von einer Konf igurationszustande vorgeben- 
den Einheit zu empfangen. 

3. Datenverarbeitungseinheit nach dem vorhergehenden An- 
spruch, dadurch gekennzeichnet, dass die Konf igurations- 
zustande vorgebende Einheit eine Compilereinheit und/oder 
eine Zellkonf igurationsvorgabeeinheit umfasst. 

4 . Datenverarbeitungseinheit nach einem der vorherigen An- 
spruche, dadurch gekennzeichnet, dass das Taktvorgabemit- 
tel dazu ausgebildet ist, den Solltakt von einer Lo- 
gikzelle zu empfangen. 

5. Datenverarbeitungseinheit nach einem der vorherigen An- 
spriiche, dadurch gekennzeichnet, dass das Taktvorgabemit- 
tel wenigstens eine Zentraltaktvorgabeeinheit und wenig- 
stens eine Lokaltaktgeneriereinheit zur Generierung des 
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Lokaltaktes aus dem vorgegebenen Zentraltakt, insbesonde- 
re je Zelle eine Zeitabtaktgeneriereinheit , umfasst. 

6. Datenverarbeitungseinheit nach einem der vorherigen An- 
spruche, dadurch gekennzeichnet, dass zumindest ein Teil 
der Logikzellen zumindest eine ALU umfassen und/oder 
durch eine solche gebildet sind. 

7. Datenverarbeitungseinheit nach einem der vorherigen An- 
spruche, dadurch gekennzeichnet , dass zumindest einem 
Teil der Logikzellen zumindest ein Speicher und/oder Re- 
gister zugeordnet ist. 

8. Datenverarbeitungseinheit nach einem der vorherigen An- 
spruche, dadurch gekennzeichnet, dass eine Vielzahl iden- 
tischer Logikzellen vorgesehen ist. 

9. Datenverarbeitungseinheit nach einem der vorherigen An- 
spriiche, dadurch gekennzeichnet, dass alle Logikzellen 
identisch sind. 

10. Verfahren zum Betreiben eines in unterschiedlichen Konfi- 
gurationszustande bringbaren Feldes getakteter Logikzel- 
len, dadurch gekennzeichnet, dass zumindest zeitweilig 
fur wenigstens eine erste Zelle ein erster Zustand b.e- 
stimmt, abhangig vom erst en Zustand ein der ersten Zelle 
zuzuordnender Takt ermittelt und die Zelle mit diesem 
Takt betrieben wird, fur wenigstens eine weitere Zelle 
ein zweiter Zustand bestimmt wird, abhangig vom zweiten 
Zustand ein der zweiten Zelle zuzuordnender zweiter Takt 
ermittelt und die zweite Zelle mit diesem vom ersten Takt 
verschiedenen zweiten Takt betrieben wird. 
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11. Verfahren nach dem vorhergehenden Anspruch, dadurch ge- 
kennzeichnet, dass fur wenigstens eine erste Zelle der 
Takt zusammen mit ihrer oder bestimmt durch ihre Konfigu- 
ration vorgegeben wird. 

12. Verfahren nach einem der vorhergehenden Verf ahrensansprii- 
che, worin eine Gruppe von Zellen gerneinsam zur Ausfuh- 
rung von algebraischen und/oder anderen Operationen kon- 
figuriert werden, die eine unterschiedliche Anzahl von 
Taktzyklen erfordern, wobei zumindest eine Zelle, die ei- 
ne Operation ausfuhrt, welche weniger Taktzellen erfor- 
dert als jene Operation, die innerhalb der Gruppe am mei- 
sten Taktzyklen erfordert, langsamer getaktet wird als 
wenigstens eine andere Zelle. 

13. Verfahren nach einem der vorhergehenden Verf ahrensanspru- 
che, dadurch gekennzeichnet , dass Zellen zumindest einer 
Gruppe zur sequentiellen Datenverarbeitung konfiguriert 
werden. 

•14. Verfahren nach einem der vorhergehenden Verf ahrensansprii- 
che, dadurch gekennzeichnet, dass das Feld in wenigstens 
zwei Zellgruppen zur Ausfuhrung wenigstens zweier unter- 
schiedlicher Aufgaben konfiguriert wird, denen eine un- 
terschiedliche Prioritat zugeordnet wird und jene Zell- 
gruppe, die zur Ausfuhrung der Aufgabe. mit geringerer 
Prioritat angeordnet ist, mit geringerer Taktfrequenz ge- 
taktet ist. 

15. Verfahren nach einem der vorhergehenden Verf ahrensanspru- 
che, dadurch gekennzeichnet, dass der Zustand einer Span 
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nungsversorgungsquelle und/oder eine Temperatur bestimmt 
und die Zelltaktung in Abhangigkeit vom so bestimmten 
Spannungs- und/oder Temperaturzustand bestimmt wird. 

16. Verfahren zum Betrieb einer Anordnung rekonf igurierbarer 
Logikelemente, die in unterschiedlichen Konf igurationen 
betrieben werden konnen, dadurch gekennzeichnet, dass fur 
eine Vielzahl moglicher, insbesondere gleichzeitig in das 
Feld einkonf igurierter Konf igurationen eine noch zulassi- 
ge Frequenz, insbesondere die noch ausfuhrbare Maximal- 
frequenz bestimmt wird und eine Vielzahl von Zellen mit 
dieser Frequenz betrieben werden, wobei die Vielzahl von 
Zellen grofler ist als jene Vielzahl, die zur Ausfuhrung 
dieser sogenannten langsamsten Konf iguration gehort und 
wobei die Vielzahl insbesondere das gesamte Feld der kon- 
f igurierbaren Elemente umfassen kann. 

17. Verfahren zum Betrieb einer Anordnung rekonf igurierbarer 
Logikelemente, die in unterschiedlichen Konf igurationen 
betrieben werden kdnnen, dadurch gekennzeichnet, dass 
Konfigurationen so gewahlt werden, dass unter Berucksich- 
tigung des Signaltransf ers liber . Busleitungen maximale 
Frequenzen bei der Ubertragung uber Bussysteme erhalten 
werden. 



- 37 - 



SUBSTITUTE SHEET (RULE 26) 



WO 02/071196 



-1/7- 



PCT/EP02/02402 



0103 




o 

v— 
O 


$ 


o 

O 


o 

1 

CM 

o 
o 

















































































































































































































































































































































































































































































































































il 



WO 02/071196 



-2/7- 



PCT/EP02/02402 




WO 02/071196 



-3/7- 



PCT/EP02/02402 



o 


N 

»| 


CM 





+ 


elk 


eg 

m 

cv 


N 

CO £ 








CM ^ 
CO o 




CD N 
CM 2 


oo 

CM 


CM 

CO 


o T ~ 


CO £ 

T- O 


CM 


CO N 
21 


CO 


CD 


* 




CO 


CO .2 
"~ 2 


00 


CM 
CO 




o 


CM 
CO 


N 

CO 






+ 


o 


CM 
CO 


N 







n 

CO 
D) 

mmm 
Urn 



' Oi + 
, o - 


CM 

o *> 

T— 

o 


CM I 

o 


I CN 

. o + 


(D 
CM 

O i 

t— 

O 

m mm m 


CM 

O .* ' 
J 


0102a 
I/O 


0102b 
n.c. 


0102c 
n.c. 



(0 
CO 

db 
iZ 



WO 02/071196 



-4/7- 



PCT/EP02/02402 




WO 02/071196 



-5/7- 



PCT/EP02/02402 



0205b 
0205a 

0205b 
0205a 

0205b 



ow| oy 

j 


OX 


oz ioa j 


iaj ib 


ic 


• ■ ! ■ CO 

id le b 



oa 



n-1 



ia. 



la 



n+1 



oa i £J 

in. 1 0 
\ CD 
!0 



oa. 



oa 



n 



0205a jia r 



CD 



ia. 





CM 


CO 








CL 


CL 


CL 


CL 


° 


O 


o 


O 


O 



o 

CD 
O 



(0 
CD 

ri> 




oo 
o 

CM 

o 



Q. 
O 


CM 
CL 
O 


CO 
CL 

o 


CL 
O 


CL 

o 


• * V 






/ 

C— 


y 

/' 

/ 




WO 02/071196 



-6/7- 



PCT/EP02/02402 



00 

o 

CM 

o 





CM 








XL 



-Q 





<3 


CO 






o 




J* 





(0 




O 




D) 


O) 






y 






y 










ri> 

LL 




CM 
O 



CO 



CM 

CM 
O 



WO 02/071196 



-7/7- 



PCT/EP02/02402 



0205b 
0205a 

0205b 
0205a 
0205b 
0205a 
0205b 
0205a 



0205b 
0205a 
0205b 
0205a 
0205b 
0205a 



i — 1 

! 

! 
i 


oajob n 

nj n 


r — r — i — *- — -i 

I i 0C n 


ten 


!■>„ 


i j 1 1 

icj i 




r 

jov 

} 


T 

owjoy 

1 


OX | oz !oc n 


1 in 

i 


io j ip 


icjiqj ir 


loq 


or !ob n 

\ n 


1 i 1 

os i ot 1 ou 


UJ 


y iii>„ 

J : n 


1 — i — i — -1 
ik 1 il Mm 


j oi ' 


j 

oajom 

— i — 1 


1 — i — i — . 
on j oo j op 


x 1 

l i3 n 


id | ie 


if ! ig ! ih 



0205b 
0205a 
0205b 
0205a 
0205b oa, 
0205a 



1 OCn-1 


0C n 


i ic„ 


iC h + 1 


! ob „ 


ob 

n 


I ■>» 


ib n + 1 


6a 

: n- 


oa 

I n 


I 

» 


l3 n+1 



OC, 



oc. 



o 
o 



CO 

o 

I s - 

o 



(0 

o LL 



| ic ? 


• • 

IC nl ,C ? i 


j. ob 7 






I ' b ? 






|oa ? 




oa ? ! 


l' a n 


ia ? | 


Oj 


CM 
CO 




T — 

o 


CM 

o 


CO i 



